<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>淘宝搜索框</title>
    <!-- 导入页面的基本样式 -->
    <link rel="stylesheet" href="./css/search.css" />
    <!-- 导入 jQuery -->
    <script src="./lib/jquery.js"></script>
    <script src="./lib/template-web.js"></script>
  </head>
  <body>
    <div class="container">
      <!-- Logo -->
      <img src="./images/taobao_logo.png" alt="" class="logo" />

      <div class="box">
        <!-- tab 栏 -->
        <div class="tabs">
          <div class="tab-active">宝贝</div>
          <div>店铺</div>
        </div>
        <!-- 搜索区域（搜索框和搜索按钮） -->
        <div class="search-box">
          <input type="text" class="ipt" placeholder="请输入要搜索的内容" />
          <button class="btnSearch">搜索</button>
        </div>
        <!-- 搜索建议列表 -->
        <div id="suggest-list"></div>
      </div>
    </div>
    <!-- 模板结构 -->
    <script type="text/html" id="tpl-suggestList">
      {{each result}}
      <div class="suggest-item">{{$value[0]}}</div>
      {{/each}}
    </script>
    <script>
      $(function () {
        // 缓存对象
        var cacheObj = {};
        // 渲染建议列表
        function renderSuggestList(res) {
          // ...省略其他代码
          // 将搜索的结果，添加到缓存对象中
          var k = $("#ipt").val().trim();
          cacheObj[k] = res;
        }
        //监听输入框改变事件
        $(".ipt").on("keyup", function () {
          var txt = $(this).val().trim();
          if (txt.length <= 0) {
            return $("#suggest-list").empty().hide();
          }
          // 优先从缓存中获取搜索建议
          if (cacheObj[txt]) {
            return renderSuggestList(cacheObj[txt]);
          }
          clearTimeout(timer);
          debounceSearch(txt);
        });
        //封装获取服务器列表函数
        function getList(val) {
          $.ajax({
            url: "https://suggest.taobao.com/sug?q=" + val,
            // 指定要发起的是 JSONP 请求
            dataType: "jsonp",
            success: function (res) {
              renderSuggestList(res);
            },
          });
        }
        //渲染模板引擎函数
        function renderSuggestList(res) {
          if (res.result.length <= 0) {
            return $("#suggest-list").empty().hide();
          }
          var htmlStr = template("tpl-suggestList", res);
          $("#suggest-list").html(htmlStr).show();
        }
        //定义防抖的函数
        var timer = null;
        function debounceSearch(keywords) {
          timer = setTimeout(function () {
            // 发起 JSONP 请求
            getList(keywords);
          }, 500);
        }
      });
    </script>
  </body>
</html>
